\(\int (c x)^m (a+b x)^n \, dx\) [731]

   Optimal result
   Rubi [A] (verified)
   Mathematica [A] (verified)
   Maple [F]
   Fricas [F]
   Sympy [C] (verification not implemented)
   Maxima [F]
   Giac [F]
   Mupad [F(-1)]

Optimal result

Integrand size = 13, antiderivative size = 52 \[ \int (c x)^m (a+b x)^n \, dx=\frac {(c x)^{1+m} (a+b x)^n \left (1+\frac {b x}{a}\right )^{-n} \operatorname {Hypergeometric2F1}\left (1+m,-n,2+m,-\frac {b x}{a}\right )}{c (1+m)} \]

[Out]

(c*x)^(1+m)*(b*x+a)^n*hypergeom([-n, 1+m],[2+m],-b*x/a)/c/(1+m)/((1+b*x/a)^n)

Rubi [A] (verified)

Time = 0.01 (sec) , antiderivative size = 52, normalized size of antiderivative = 1.00, number of steps used = 2, number of rules used = 2, \(\frac {\text {number of rules}}{\text {integrand size}}\) = 0.154, Rules used = {68, 66} \[ \int (c x)^m (a+b x)^n \, dx=\frac {(c x)^{m+1} (a+b x)^n \left (\frac {b x}{a}+1\right )^{-n} \operatorname {Hypergeometric2F1}\left (m+1,-n,m+2,-\frac {b x}{a}\right )}{c (m+1)} \]

[In]

Int[(c*x)^m*(a + b*x)^n,x]

[Out]

((c*x)^(1 + m)*(a + b*x)^n*Hypergeometric2F1[1 + m, -n, 2 + m, -((b*x)/a)])/(c*(1 + m)*(1 + (b*x)/a)^n)

Rule 66

Int[((b_.)*(x_))^(m_)*((c_) + (d_.)*(x_))^(n_), x_Symbol] :> Simp[c^n*((b*x)^(m + 1)/(b*(m + 1)))*Hypergeometr
ic2F1[-n, m + 1, m + 2, (-d)*(x/c)], x] /; FreeQ[{b, c, d, m, n}, x] &&  !IntegerQ[m] && (IntegerQ[n] || (GtQ[
c, 0] &&  !(EqQ[n, -2^(-1)] && EqQ[c^2 - d^2, 0] && GtQ[-d/(b*c), 0])))

Rule 68

Int[((b_.)*(x_))^(m_)*((c_) + (d_.)*(x_))^(n_), x_Symbol] :> Dist[c^IntPart[n]*((c + d*x)^FracPart[n]/(1 + d*(
x/c))^FracPart[n]), Int[(b*x)^m*(1 + d*(x/c))^n, x], x] /; FreeQ[{b, c, d, m, n}, x] &&  !IntegerQ[m] &&  !Int
egerQ[n] &&  !GtQ[c, 0] &&  !GtQ[-d/(b*c), 0] && ((RationalQ[m] &&  !(EqQ[n, -2^(-1)] && EqQ[c^2 - d^2, 0])) |
|  !RationalQ[n])

Rubi steps \begin{align*} \text {integral}& = \left ((a+b x)^n \left (1+\frac {b x}{a}\right )^{-n}\right ) \int (c x)^m \left (1+\frac {b x}{a}\right )^n \, dx \\ & = \frac {(c x)^{1+m} (a+b x)^n \left (1+\frac {b x}{a}\right )^{-n} \, _2F_1\left (1+m,-n;2+m;-\frac {b x}{a}\right )}{c (1+m)} \\ \end{align*}

Mathematica [A] (verified)

Time = 0.01 (sec) , antiderivative size = 48, normalized size of antiderivative = 0.92 \[ \int (c x)^m (a+b x)^n \, dx=\frac {x (c x)^m (a+b x)^n \left (1+\frac {b x}{a}\right )^{-n} \operatorname {Hypergeometric2F1}\left (1+m,-n,2+m,-\frac {b x}{a}\right )}{1+m} \]

[In]

Integrate[(c*x)^m*(a + b*x)^n,x]

[Out]

(x*(c*x)^m*(a + b*x)^n*Hypergeometric2F1[1 + m, -n, 2 + m, -((b*x)/a)])/((1 + m)*(1 + (b*x)/a)^n)

Maple [F]

\[\int \left (c x \right )^{m} \left (b x +a \right )^{n}d x\]

[In]

int((c*x)^m*(b*x+a)^n,x)

[Out]

int((c*x)^m*(b*x+a)^n,x)

Fricas [F]

\[ \int (c x)^m (a+b x)^n \, dx=\int { {\left (b x + a\right )}^{n} \left (c x\right )^{m} \,d x } \]

[In]

integrate((c*x)^m*(b*x+a)^n,x, algorithm="fricas")

[Out]

integral((b*x + a)^n*(c*x)^m, x)

Sympy [C] (verification not implemented)

Result contains complex when optimal does not.

Time = 3.98 (sec) , antiderivative size = 37, normalized size of antiderivative = 0.71 \[ \int (c x)^m (a+b x)^n \, dx=\frac {a^{n} c^{m} x^{m + 1} \Gamma \left (m + 1\right ) {{}_{2}F_{1}\left (\begin {matrix} - n, m + 1 \\ m + 2 \end {matrix}\middle | {\frac {b x e^{i \pi }}{a}} \right )}}{\Gamma \left (m + 2\right )} \]

[In]

integrate((c*x)**m*(b*x+a)**n,x)

[Out]

a**n*c**m*x**(m + 1)*gamma(m + 1)*hyper((-n, m + 1), (m + 2,), b*x*exp_polar(I*pi)/a)/gamma(m + 2)

Maxima [F]

\[ \int (c x)^m (a+b x)^n \, dx=\int { {\left (b x + a\right )}^{n} \left (c x\right )^{m} \,d x } \]

[In]

integrate((c*x)^m*(b*x+a)^n,x, algorithm="maxima")

[Out]

integrate((b*x + a)^n*(c*x)^m, x)

Giac [F]

\[ \int (c x)^m (a+b x)^n \, dx=\int { {\left (b x + a\right )}^{n} \left (c x\right )^{m} \,d x } \]

[In]

integrate((c*x)^m*(b*x+a)^n,x, algorithm="giac")

[Out]

integrate((b*x + a)^n*(c*x)^m, x)

Mupad [F(-1)]

Timed out. \[ \int (c x)^m (a+b x)^n \, dx=\int {\left (c\,x\right )}^m\,{\left (a+b\,x\right )}^n \,d x \]

[In]

int((c*x)^m*(a + b*x)^n,x)

[Out]

int((c*x)^m*(a + b*x)^n, x)